var layer = layui.layer
var form = layui.form

// 调用 initEditor() 方法，初始化富文本编辑器
initEditor()
initCate()
function initCate() {
  $.ajax({
    url: '/my/article/cates',
    type: 'get',
    success: function (res) {
      if (res.status != 0) {
        return layer.msg('数据请求失败！')
      }

      // 调用模板引擎  渲染 分类的下拉菜单
      var htmlStr = template('tpl-cate', res)
      $('[name=cate_id]').html(htmlStr)
      // 一定要记得调用 form.render 方法
      form.render()
    }
  })
}

// 1. 初始化图片裁剪器
var $image = $('#image')

// 2. 裁剪选项
var options = {
  aspectRatio: 400 / 280,
  preview: '.img-preview'
}

// 3. 初始化裁剪区域
$image.cropper(options)

// 为选择封面的按钮，添加点击事件 处理函数
$('#btnChooseImage').on('click', function () {
  $('#coverFile').click()
})


//  监听 coverFile 的 change 事件，获取用户选择的文件列表
$('#coverFile').on('change', function (e) {
  // 获取文件的列表数组
  var files = e.target.files

  // 判断用户是否 选择了文件
  if (files.length <= 0) {
    return
  }

  // 根据文件，创建对应的 URL地址
  var newImgURL = URL.createObjectURL(files[0])

  $image
    .cropper('destroy') // 销毁旧的裁剪区域
    .attr('src', newImgURL) // 重新设置图片路径
    .cropper(options) // 重新初始化裁剪区域
})


// 定义文章的发布状态
// 为存为草稿按钮，绑定点击事件处理函数
var art_state = '已发布';
$('#btnSave2').on('click', function () {
  art_state = '草稿'
})


//  利用延时器来，延迟获取到 富文本中的数据
setTimeout(function () {
  $('#form-pub').on('submit', function (e) {
    e.preventDefault()
    // 快速获取到表单中的数据， 利用[0],将用jq方法获取到的对象 转换为原生对象
    var fd = new FormData($(this)[0])
    fd.append('state', art_state)
    // 4. 将封面裁剪过后的图片，输出为一个文件对象
    $image
      .cropper('getCroppedCanvas', {
        // 创建一个 Canvas 画布
        width: 400,
        height: 280
      })
      .toBlob(function (blob) {
        // 将 Canvas 画布上的内容，转化为文件对象
        // 得到文件对象后，进行后续的操作
        // 5. 将文件对象，存储到 fd 中
        fd.append('cover_img', blob)

        // 6. 发起 ajax 数据请求
        $.ajax({
          type: 'post',
          url: '/my/article/add',
          data: fd,
          // data 里面传递的参数为formData格式的数据，所有必须添加以下两个配置项
          contentType: false,
          processData: false,
          success: function (res) {
            if (res.status != 0) {
              return layer.msg('发布文章失败！')
            }
            layer.msg('文章发布成功')

            // 文章发表成功后 跳转到文章列表页面上
            location.href = '/article/art_list.html'

          }
        });
      });
  });
}, 100)
